草庐IT

php - AS 或不 AS,查询

全部标签

ruby - ruby有数组方法select吗!或不?

>a=%w(abc)=>["a","b","c"]>a.select!{|e|!e.nil?}NoMethodError:undefinedmethod`select!'for["a","b","c"]:Arrayfrom(irb):2ruby1.8.7(2010-04-19patchlevel253)[i686-darwin10.5.0],MBARI0x6770,RubyEnterpriseEdition2010.02文档说有一个叫做select的方法!在数组中。http://www.ruby-doc.org/core/classes/Array.html#M000252

ruby - 如何让 rspec 不显示数据库查询而只显示带有 rails_12factor 的点?

ruby:2.0rails:3.2.17rspec:2.14.8Database:mysqlrspecspec用于仅输出点。当我推送到Heroku并且最近添加了rails_12factorgem来绕过它时,我收到了弃用警告。但是,现在在本地运行规范时,我会得到每个事务的详细数据库输出。当我需要它时这是一个很好的选择,否则它会产生很多不需要和分散注意力的输出。所以我想要一个将它用于Heroku而不是本地的选项。请注意,这不会通过使用格式化程序来解决,例如rspecspec-fd此外,如果出现错误,在这种冗长程度下,错误几乎总是滚出当前页面...09:50:39durrantmCastle

ruby - 更新到 cocoapods 0.32.1 后无法运行 sudo pod install,错误为 "You cannot run CocoaPods as root. (CLAide::Help)"

我在更新到最新版本0.32.1后运行sudopodinstall命令时发现了一个问题。早些时候它工作得很好。当我尝试使用旧的cocoapods安装pod时,它要求我更新到最新的cocoapods版本,即0.32.1。在我通过cocoapodsgem更新后,我无法在我的Xcode项目中执行sudopodinstall。它给了我以下错误。±sudopodinstallruby-1.9.3-p0Password:/Users/username/.rvm/rubies/ruby-1.9.3-p0/lib/ruby/gems/1.9.1/gems/claide-0.5.0/lib/claide/

ruby-on-rails - Rails 查询执行导致数据库峰值

我的Rails应用程序出现问题,一些随机查询需要大约5秒或更长时间才能完成。大多数时候,查询非常简单(select*fromxwhereid=?),而且字段甚至也被编入索引。这里有一些关于设置的更多信息:反向nginx代理背后的Puma3.5.04个worker,每个worker最少4个,最多8个线程。Rubyv2.2.3,Railsv4.2.4PostgreSQL9.4数据库线程池设置为最多60个连接监控应用8GBRAM、4个CPU、SSD。我在查看Appsignal中的查询性能时发现了这一点。我注意到大多数查询在几毫秒内完成,然后时不时地,仍然在同一个请求中,有多个查询需要5秒以上

ruby-on-rails - 在 Rspec 中用项目符号标记 N+1 查询

我正在尝试使用bulletgem标记N+1并在代码中添加计数器缓存的位置.但是手动执行所有检查N+1查询的操作似乎非常痛苦,所以我尝试使用Bullet和Rspec,使用他们推荐的设置步骤:#config/environments/test.rbconfig.after_initializedoBullet.enable=trueBullet.bullet_logger=trueBullet.raise=true#raiseanerrorifn+1queryoccursend#spec/spec_helper.rbifBullet.enable?config.before(:each)d

ruby-on-rails - ActiveRecord:查询未对 STI 子类使用正确的类型条件

我有一组STI子类继承自User基类。我发现在子类定义中的某些条件下,对子类的查询没有正确使用type条件。classUser在开发中加载Rails控制台时,它会按照我的预期进行:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`IN('Admin')但是当点击应用程序(localhost/pow)时,它缺少type条件,我明白了:Admin:SELECT`users`.*FROM`users`但在部署到暂存服务器时不是来自应用程序:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`

ruby-on-rails - Rails as_json 问题 - 如何有效地包含嵌套对象?

我遇到了一个问题,我正在使用as_json方法,以及如何有效地返回JSON中的对象AND它也是belongs_to对象作为JSON,其中belongs_to对象具有它自己的belongs_to对象。代码可能会更好地解释它。无效的方式警报类classAlert:message)endend消息类defas_json(options={})super(methods:[:timestamp,:num_photos,:first_photo_url,:tag_names],include:{camera:{only:[:id,:name]},position:{only:[:id,:name

ruby-on-rails - 如何覆盖 'as_json' 或 'to_json' 方法,以便 'respond_to' 不包含指定信息?

我正在使用RubyonRails3,我想覆盖(可能在模型文件中)as_json或to_json方法以respond_to不包含某些信息的HTTP请求。在我的帐户模型中我有defas_json(options={})super(:except=>[:password])end在我的Controller中我有format.json{render:json=>@account,:status=>200}例如,当我向/account/1.json发出请求时,我还返回了出于安全原因我不想要的密码属性。那么,如何防止包含指定信息?我能做到,而且行得通format.json{render:json=

sql - SQL 查询的最大长度

SELECTf.*FROMfeedsf,user_feedsufWHERE(f.id=uf.feed_idanduf.user_idin(1,2,5,6,23,45))ORDERBYcreated_atDESC这是用于构建用户提要的查询。这个查询的问题是“uf.user_idin()”随着用户关注的用户数量的增加而增加。SQL查询允许的最大长度是多少?有没有更好的方法来实现上面的查询?注意:我正在使用ActiveRecord和Postgres。 最佳答案 PostgreSQL可以处理的查询的最大长度是2147483648个字符(带符

ruby-on-rails - 如何使用 Ruby 中哈希的查询参数构造 URI

如何通过传递哈希来构造带有查询参数的URI对象?我可以生成查询:URI::HTTPS.build(host:'example.com',query:"a=#{hash[:a]},b=#{[hash:b]}")产生https://example.com?a=argument1&b=argument2但是我认为为许多参数构造查询字符串将不可读且难以维护。我想通过传递哈希来构造查询字符串。就像下面的例子:hash={a:'argument1',b:'argument2'#...dozenmorearguments}URI::HTTPS.build(host:'example.com',que